package simple.tree;

import struct.TreeNode;

/**
 * <a href="https://leetcode.cn/problems/sum-of-root-to-leaf-binary-numbers/">1022. 从根到叶的二进制数之和</a>
 * 给出一棵二叉树，其上每个结点的值都是 0 或 1 。每一条从根到叶的路径都代表一个从最高有效位开始的二进制数。
 * 例如，如果路径为 0 -> 1 -> 1 -> 0 -> 1，那么它表示二进制数 01101，也就是 13 。
 * 对树上的每一片叶子，我们都要找出从根到该叶子的路径所表示的数字。
 * 返回这些数字之和。题目数据保证答案是一个 32 位 整数。
 * 示例 1：
 *   输入：root = [1,0,1,0,1,0,1]
 *   输出：22
 *   解释：(100) + (101) + (110) + (111) = 4 + 5 + 6 + 7 = 22
 * 示例 2：
 *   输入：root = [0]
 *   输出：0
 * 提示：
 *   树中的节点数在 [1, 1000] 范围内
 *   Node.val 仅为 0 或 1
 * @author 刘学松
 * @date 2023-07-05 11:14
 */
public class 从根到叶的二进制数之和 {
    public int sumRootToLeaf(TreeNode root) {
        if (root.left == null && root.right == null) {
            return root.val;
        }
        int val = (root.val << 1);
        if (root.left != null && root.right != null) {
            root.left.val += val;
            root.right.val += val;
            return sumRootToLeaf(root.left) + sumRootToLeaf(root.right);
        } else if (root.left != null) {
            root.left.val += val;
            return sumRootToLeaf(root.left);
        } else {
            root.right.val += val;
            return sumRootToLeaf(root.right);
        }
    }
}
